{{!
  Copyright (c) HashiCorp, Inc.
  SPDX-License-Identifier: BUSL-1.1
~}}

<LinkedBlock
  @params={{array "vault.cluster.secrets.backend.show" (if this.keyTypeValue (concat "role/" @item.id) @item.id)}}
  class="list-item-row"
  data-test-secret-link={{@item.id}}
  @encode={{true}}
  @queryParams={{secret-query-params @backendType @item.type}}
>
  <div class="columns is-mobile">
    <div class="column is-10">
      <LinkTo
        @route={{concat "vault.cluster.secrets.backend.show"}}
        @model={{if this.keyTypeValue (concat "role/" @item.id) @item.id}}
        @query={{secret-query-params @backendType @item.type}}
        class="has-text-black has-text-weight-semibold"
      >
        <Icon @name="user" class="has-text-grey-light is-pulled-left" />
        <div class="role-item-details">
          <span class="is-underline">{{if (eq @item.id " ") "(self)" (or @item.keyWithoutParent @item.id)}}</span>
          <span class="tag has-text-grey-dark">{{this.keyTypeValue}}</span>
        </div>
      </LinkTo>
    </div>
    <div class="column has-text-right">
      <PopupMenu name="secret-menu">
        <nav class="menu">
          <ul class="menu-list">
            {{#if @item.canEdit}}
              <li class="action">
                <SecretLink @mode="edit" @secret={{@item.id}} class="has-text-black has-text-weight-semibold">
                  Edit connection
                </SecretLink>
              </li>
            {{/if}}
            {{#if @item.canEditRole}}
              <li class="action">
                <SecretLink @mode="edit" @secret={{concat "role/" @item.id}} class="has-text-black has-text-weight-semibold">
                  Edit Role
                </SecretLink>
              </li>
            {{/if}}
            {{#if @item.canReset}}
              <li class="action">
                <Hds::Button
                  @text="Reset connection"
                  @color="secondary"
                  class="link"
                  {{on "click" (fn this.resetConnection @item.id)}}
                />
              </li>
            {{/if}}
            {{#if (and (eq @item.type "dynamic") @item.canGenerateCredentials)}}
              <li class="action">
                <LinkTo
                  @route="vault.cluster.secrets.backend.credentials"
                  @model={{@item.id}}
                  @query={{hash roleType=this.keyTypeValue}}
                >
                  Generate credentials
                </LinkTo>
              </li>
            {{else if (and (eq @item.type "static") @item.canGetCredentials)}}
              <li class="action">
                <LinkTo
                  @route="vault.cluster.secrets.backend.credentials"
                  @model={{@item.id}}
                  @query={{hash roleType=this.keyTypeValue}}
                >
                  Get credentials
                </LinkTo>
              </li>
            {{/if}}
            {{#if (and @item.canRotateRoleCredentials (eq this.keyTypeValue "static"))}}
              <li class="action">
                <Hds::Button
                  @text="Rotate credentials"
                  @color="secondary"
                  class="link"
                  {{on "click" (fn this.rotateRoleCred @item.id)}}
                />
              </li>
            {{/if}}
            {{#if @item.canRotateRoot}}
              <li class="action">
                <Hds::Button
                  @text="Rotate root credentials"
                  @color="secondary"
                  class="link"
                  {{on "click" (fn this.rotateRootCred @item.id)}}
                />
              </li>
            {{/if}}
          </ul>
        </nav>
      </PopupMenu>
    </div>
  </div>
</LinkedBlock>